”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 使用 Golang 和 GoFr 更改运行时日志级别

使用 Golang 和 GoFr 更改运行时日志级别

发布于2024-07-30
浏览:188

在本文中,我将分享如何在不重新启动应用程序的情况下更改应用程序的日志级别。

介绍

日志级别通常被认为是按重要性排序:在开发中打开“不重要”级别(通知、调试等),但在开发中仅启用“最重要”级别(警告、错误等)。生产环境,CPU 时间和磁盘空间等资源非常宝贵。

但是,如果您的应用程序运行在 ERROR 级别并且您开始面临许多问题,但您无法从 ERROR 级别日志中找出答案,那么通过重新部署应用程序来更改日志级别将花费大量时间和资源。

此外,在生产中以 INFO 或 DEBUG 级别运行应用程序将生成大量日志,这些日志可能会压垮日志系统,导致 I/O 操作和资源消耗增加。

为了解决这些问题,GoFr - 终极 Golang 框架提供了一种安全的方法来更改日志级别,而无需重新启动应用程序。

更改日志级别

要更改日志级别,任何 GoFr 应用程序都需要以下配置:

REMOTE_LOG_URL= (e.g., https://log-service.com/log-levels?id=1)

GoFr 默认每 15 秒获取一次提供的端点以获取最新的日志级别,可以通过添加以下配置来增加或减少此间隔。

REMOTE_LOG_FETCH_INTERVAL= (default: 15)

日志级别服务

GoFr 要求 URL 的响应采用以下格式,并带有两个必填字段:

{
    "data": {
       "serviceName": "test-service",
       "logLevel": "DEBUG"
    }
}

让我们创建日志级别服务,它将为我们的应用程序提供日志级别。

我将使用 GoFr 创建服务,请参阅文档以了解更多信息。

我们将使用 MySQL 作为数据库,要添加 MySQL,请在 configs 目录中的 .env 文件中添加以下配置。

DB_HOST=localhost
DB_USER=root
DB_PASSWORD=password
DB_NAME=log-level
DB_PORT=2001
DB_DIALECT=mysql

要运行 MySQL docker 容器,请运行以下命令

docker run --name gofr-logger -e MYSQL_ROOT_PASSWORD=password -e MYSQL_DATABASE=log-level -p 2001:3306 -d mysql:8.0.30

让我们添加带有迁移的 main.go 文件来创建表,我们将使用 AddRESTHandler 功能来注册路由。

main.go

package main

import (
 "gofr.dev/pkg/gofr"
 "gofr.dev/pkg/gofr/migration"
)

const createTable = `CREATE TABLE level (
    id INT PRIMARY KEY,
    service_name VARCHAR(255) NOT NULL,
    log_level VARCHAR(50) NOT NULL
);
`

func createTableLevel() migration.Migrate {
 return migration.Migrate{
  UP: func(d migration.Datasource) error {
   _, err := d.SQL.Exec(createTable)
   if err != nil {
    return err
   }

   return nil
  },
 }
}

type Level struct {
 ID          int    `json:"id"`
 ServiceName string `json:"serviceName"`
 LogLevel    string `json:"logLevel"`
}

func (u *Level) RestPath() string {
 return "level"
}

func main() {
 app := gofr.New()

 app.Migrate(map[int64]migration.Migrate{1: createTableLevel()})

 err := app.AddRESTHandlers(&Level{})
 if err != nil {
  app.Logger().Fatalf("Failed to register routes for level struct: %v", err)
 }

 app.Run()
}

运行日志服务后我们会看到如下日志:

LOGS FOR LOG-LEVEL CHANGE SERVICE STARTUP

我们已注册所有 REST 路线。

要创建服务,请发送以下请求:

curl --location 'localhost:8000/level' \
--header 'Content-Type: application/json' \
--data '{
    "id":1,
    "logLevel":"INFO",
    "serviceName":"gofr-app"
}'

要更新日志级别,请发送以下请求:

curl --location --request PUT 'localhost:8000/level/1' \
--header 'Content-Type: application/json' \
--data '{
    "id":1,
    "logLevel":"DEBUG",
    "serviceName":"gofr-app"
}'

要获取日志级别,请发送以下请求:

curl --location 'localhost:8000/level/1'

相同的 URL 将用于我们的应用程序的配置中,其日志级别必须远程更改。

结论

通过使用 GoFr 远程日志级别更改功能,您将获得以下好处:

  • 轻松调整:
    随时修改日志级别,无需重新启动应用程序。这在故障排除期间特别有用。

  • 增强可见性:
    轻松切换到更详细的日志级别(例如 DEBUG)以更深入地了解特定问题,然后切换回不太详细的级别(例如 INFO)以进行常规操作。

  • 改进的性能:
    生成大量日志会使日志系统不堪重负,导致 I/O 操作和资源消耗增加,更改为警告或错误级别可减少日志数量,增强性能,并降低云成本

通过给予 ⭐star 支持 GoFr: https://github.com/gofr-dev/gofr

此外,您可以访问免费公共端点来导出和查看应用程序的跟踪@tracer.gofr.dev。 
要启用它,请在您的 .env 文件中添加以下配置

TRACE_EXPORTER=gofr

其他福利:
如果您在开发或撰写文章方面为 GOFR 做出了贡献。您可以通过填写 GitHub 上的表格来获得免费的 赠品(T 恤、贴纸) 自述文件(位于底部)。

版本声明 本文转载于:https://dev.to/aryanmehrotra/remote-runtime-log-level-change-using-golang-gofr-54d8?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • Java的Map.Entry和SimpleEntry如何简化键值对管理?
    Java的Map.Entry和SimpleEntry如何简化键值对管理?
    A Comprehensive Collection for Value Pairs: Introducing Java's Map.Entry and SimpleEntryIn Java, when defining a collection where each element com...
    编程 发布于2025-07-08
  • 如何使用PHP将斑点(图像)正确插入MySQL?
    如何使用PHP将斑点(图像)正确插入MySQL?
    essue VALUES('$this->image_id','file_get_contents($tmp_image)')";This code builds a string in PHP, but the function call ...
    编程 发布于2025-07-08
  • 如何使用Depimal.parse()中的指数表示法中的数字?
    如何使用Depimal.parse()中的指数表示法中的数字?
    在尝试使用Decimal.parse(“ 1.2345e-02”中的指数符号表示法表示的字符串时,您可能会遇到错误。这是因为默认解析方法无法识别指数符号。 成功解析这样的字符串,您需要明确指定它代表浮点数。您可以使用numbersTyles.Float样式进行此操作,如下所示:[&& && && ...
    编程 发布于2025-07-08
  • 如何将PANDAS DataFrame列转换为DateTime格式并按日期过滤?
    如何将PANDAS DataFrame列转换为DateTime格式并按日期过滤?
    Transform Pandas DataFrame Column to DateTime FormatScenario:Data within a Pandas DataFrame often exists in various formats, including strings.使用时间数据时...
    编程 发布于2025-07-08
  • 将图片浮动到底部右侧并环绕文字的技巧
    将图片浮动到底部右侧并环绕文字的技巧
    在Web设计中围绕在Web设计中,有时可以将图像浮动到页面右下角,从而使文本围绕它缠绕。这可以在有效地展示图像的同时创建一个吸引人的视觉效果。 css位置在右下角,使用css float and clear properties: img { 浮点:对; ...
    编程 发布于2025-07-08
  • 如何使用“ JSON”软件包解析JSON阵列?
    如何使用“ JSON”软件包解析JSON阵列?
    parsing JSON与JSON软件包 QUALDALS:考虑以下go代码:字符串 } func main(){ datajson:=`[“ 1”,“ 2”,“ 3”]`` arr:= jsontype {} 摘要:= = json.unmarshal([] byte(...
    编程 发布于2025-07-08
  • 如何高效地在一个事务中插入数据到多个MySQL表?
    如何高效地在一个事务中插入数据到多个MySQL表?
    mySQL插入到多个表中,该数据可能会产生意外的结果。虽然似乎有多个查询可以解决问题,但将从用户表的自动信息ID与配置文件表的手动用户ID相关联提出了挑战。使用Transactions和last_insert_id() 插入用户(用户名,密码)值('test','test...
    编程 发布于2025-07-08
  • 在PHP中如何高效检测空数组?
    在PHP中如何高效检测空数组?
    在PHP 中检查一个空数组可以通过各种方法在PHP中确定一个空数组。如果需要验证任何数组元素的存在,则PHP的松散键入允许对数组本身进行直接评估:一种更严格的方法涉及使用count()函数: if(count(count($ playerList)=== 0){ //列表为空。 } 对...
    编程 发布于2025-07-08
  • 在GO中构造SQL查询时,如何安全地加入文本和值?
    在GO中构造SQL查询时,如何安全地加入文本和值?
    在go中构造文本sql查询时,在go sql queries 中,在使用conting and contement和contement consem per时,尤其是在使用integer per当per当per时,per per per当per. [&​​&&&&&&&&&&&&&&&默元组方法在...
    编程 发布于2025-07-08
  • 版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    版本5.6.5之前,使用current_timestamp与时间戳列的current_timestamp与时间戳列有什么限制?
    在时间戳列上使用current_timestamp或MySQL版本中的current_timestamp或在5.6.5 此限制源于遗留实现的关注,这些限制需要对当前的_timestamp功能进行特定的实现。 创建表`foo`( `Productid` int(10)unsigned not n...
    编程 发布于2025-07-08
  • 如何简化PHP中的JSON解析以获取多维阵列?
    如何简化PHP中的JSON解析以获取多维阵列?
    php 试图在PHP中解析JSON数据的JSON可能具有挑战性,尤其是在处理多维数组时。 To simplify the process, it's recommended to parse the JSON as an array rather than an object.To do...
    编程 发布于2025-07-08
  • 为什么我的CSS背景图像出现?
    为什么我的CSS背景图像出现?
    故障排除:CSS背景图像未出现 ,您的背景图像尽管遵循教程说明,但您的背景图像仍未加载。图像和样式表位于相同的目录中,但背景仍然是空白的白色帆布。而不是不弃用的,您已经使用了CSS样式: bockent {背景:封闭图像文件名:背景图:url(nickcage.jpg); 如果您的html,css...
    编程 发布于2025-07-08
  • 如何在其容器中为DIV创建平滑的左右CSS动画?
    如何在其容器中为DIV创建平滑的左右CSS动画?
    通用CSS动画,用于左右运动 ,我们将探索创建一个通用的CSS动画,以向左和右移动DIV,从而到达其容器的边缘。该动画可以应用于具有绝对定位的任何div,无论其未知长度如何。问题:使用左直接导致瞬时消失 更加流畅的解决方案:混合转换和左 [并实现平稳的,线性的运动,我们介绍了线性的转换。这...
    编程 发布于2025-07-08
  • PHP未来:适应与创新
    PHP未来:适应与创新
    PHP的未来将通过适应新技术趋势和引入创新特性来实现:1)适应云计算、容器化和微服务架构,支持Docker和Kubernetes;2)引入JIT编译器和枚举类型,提升性能和数据处理效率;3)持续优化性能和推广最佳实践。 引言在编程世界中,PHP一直是网页开发的中流砥柱。作为一个从1994年就开始发展...
    编程 发布于2025-07-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3